<template>
  <div style="width: 80%">
    <h2 style="margin-bottom: 30px; text-align: center"><i class="el-icon-user"></i> 新增用户</h2>
    <el-form :inline="true" :model="form" :rules="rules" ref="ruleFrom" label-width="100px">
      <el-form-item label="姓名" prop="name">
        <el-input v-model="form.name" placeholder="请输入姓名"></el-input>
      </el-form-item>
      <el-form-item label="年龄" prop="age">
        <el-input v-model="form.age" placeholder="请输入年龄"></el-input>
      </el-form-item>
      <el-form-item label="性别">
        <el-radio v-model="form.sex" label="男">男</el-radio>
        <el-radio v-model="form.sex" label="女">女</el-radio>
      </el-form-item>
      <el-form-item label="联系电话" prop="phone">
        <el-input v-model="form.phone" placeholder="请输入联系电话"></el-input>
      </el-form-item>
      <el-form-item label="地址" prop="address">
        <el-input v-model="form.address" placeholder="请输入地址"></el-input>
      </el-form-item>
    </el-form>

    <div style="text-align: center">
      <el-button type="primary" @click="save">提交</el-button>

    </div>
  </div>
</template>

<script>
import request from "@/utils/request";
export default {
  name: "AddUser",
  data(){
    const checkAge = (rule, value, callback) => {
      if (!value) {
        return callback(new Error('年龄不能为空'));
      }
      if (!/^[0-9]+$/.test(value)){
        callback(new Error('请输入数字值'));
      }
      if (parseInt(value) > 120 || parseInt(value) <=0) {
        callback(new Error('请输入合理的年龄'));
      }
      callback()
    };
    const checkPhone = (rule, value, callback) => {
      if (!value) {
        return callback(new Error('号码不能为空'));
      }
      if (!/^[1][3,4,5,6,7,8,9][0-9]{9}$/.test(value)){
        callback(new Error('请输入合法的手机号'));
      }
      callback()
    };

    return{
      form: {sex:'男'},
      rules: {
        name: [
          {required: true, message: '请输入姓名', trigger: 'blur'},
        ],
        age: [
          {validator:checkAge, trigger: 'blur'},
        ],
        phone: [
          {validator:checkPhone, trigger: 'blur'},
        ]
      }
    }
  },
  methods: {
    save(){
      this.$refs['ruleFrom'].validate((valid) => {
        if (valid){
          request.post('/user/save',this.form).then(res => {
            if (res.code === '200'){
              this.$notify.success('新增成功')
              this.$router.push("/userList")
            }else {
              this.$notify.error('新增失败')
            }
          })
        }
      })

    }
  }
}
</script>

<style scoped>

</style>